Jinja2 url_for CSS grid

fullscreen view source
  • server.py
    • static folder
      • css & js files
      • all other static files
    • templates folder
      • template.html
      • all dynamic html files

server.py

from flask import *
app = Flask("static and dynamic content in jinja")

@app.route("/")
def main():
    return render_template("template.html")
 
app.run(debug=True)

templates\template.html

<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="{{ url_for('static', filename='template.css') }}">

<div id="wrapper">
  <div id="header"><h1>A new website</h1></div>
  <div id="left">
    <ul>
      <li><a href="#">hyperlink</a></li>
      <li><a href="#">hyperlink</a></li> 
      <li><a href="#">hyperlink</a></li> 
    </ul>  
  </div>
  <div id="right">
    <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean nisl magna, ultrices non ligula nec, interdum malesuada magna. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia curae; Aenean vulputate lorem condimentum, sollicitudin metus id, posuere ipsum. Nulla a nisi egestas, mattis nisl pretium, aliquam sapien. Morbi luctus velit ut nunc suscipit, non sodales urna suscipit. In ornare id risus vel ultrices. Quisque a mollis ipsum, quis iaculis nisl. Ut sit amet auctor lorem. Curabitur sed facilisis dui, pulvinar scelerisque lacus.</p>
  </div>
  <div id="footer">&copy; 2020 all rights reserved</div>
</div>
Put template.css in static folder:

static\template.css

#wrapper {
    display: grid;
    grid-template-areas:
        'header header'
        'leftcol rightcol'
        'footer footer';
    width: 90vw; /* 90% of viewport width */
    margin: auto; /* centres the element */
    /* normal size 3 rows x 2 columns: */
    grid-template-rows: 10vh auto 10vh;
    grid-template-columns: 20vw 70vw;
}

/* if the screen is small, less than 600px: */
@media screen and (max-width: 600px) {
    #wrapper {
        display: grid;
        grid-template-areas: /* stack: */
            'header'
            'leftcol'
            'rightcol'
            'footer';
        /* small size 4 rows x 1 column: */
        grid-template-rows: 10vh auto auto 10vh;
        grid-template-columns: 100vw;
    }
}

#header { background-color: firebrick; grid-area: header; }
#left { background-color: #D3D3D3; grid-area: leftcol; }
#right { background-color: salmon; grid-area: rightcol; }
#footer { background-color: papayawhip; grid-area: footer; }